package com.sojson.annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import com.sojson.annotation.factory.ExcelFactory;

/**
 * 自定义导出Excel数据注解
 *
 * @author lyh
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Excel {

    /** 导出时在excel中排序 */
    int sort() default ExcelFactory.SORT;

    /** 导出到Excel中的名字 */
    String name() default ExcelFactory.NAME;

    /** 日期格式, 如: yyyy-MM-dd */
    String dateFormat() default ExcelFactory.DATE_FORMAT;

    /** 如果是字典类型，请设置字典的type值 (如: sys_user_sex) */
    String dictType() default ExcelFactory.DICT_TYPE;

    /** 读取内容转表达式 (如: 0=男,1=女,2=未知) */
    String readConverterExp() default ExcelFactory.READ_CONVERTER_EXP;

    /** 分隔符,读取字符串组内容 */
    String separator() default ExcelFactory.SEPARATOR;

    /** BigDecimal 精度 默认: -1(默认不开启BigDecimal格式化) */
    int scale() default ExcelFactory.SCALE;

    /** BigDecimal 舍入规则 默认:BigDecimal.ROUND_HALF_EVEN */
    int roundingMode() default ExcelFactory.ROUNDING_MODE;

    /** 导出类型(0数字 1字符串) */
    ColumnType cellType() default ColumnType.STRING;

    /** 导出时在excel中每个列的高度 单位为字符 */
    double height() default ExcelFactory.HEIGHT;

    /** 导出时在excel中每个列的宽 单位为字符 */
    double width() default ExcelFactory.WIDTH;

    /** 文字后缀,如% 90 变成90% */
    String suffix() default ExcelFactory.SUFFIX;

    /** 当值为空时,字段的默认值 */
    String defaultValue() default ExcelFactory.DEFAULT_VALUE;

    /** 提示信息 */
    String prompt() default ExcelFactory.PROMPT;

    /** 设置只能选择不能输入的列内容. */
    String[] combo() default {};

    /** 是否导出数据,应对需求:有时我们需要导出一份模板,这是标题需要但内容需要用户手工填写 */
    boolean isExport() default ExcelFactory.IS_EXPORT;

    /** 另一个类中的属性名称,支持多级获取,以小数点隔开 */
    String targetAttr() default ExcelFactory.TARGET_ATTR;

    /** 是否自动统计数据,在最后追加一行统计数据总和 */
    boolean isStatistics() default ExcelFactory.IS_STATISTICS;

    /** 字段类型(0:导出导入,1：仅导出,2:仅导入) */
    Type type() default Type.ALL;

    enum Type {
        ALL(0), EXPORT(1), IMPORT(2);

        private final int value;

        Type(int value) {
            this.value = value;
        }

        public int value() {
            return this.value;
        }
    }

    enum ColumnType {
        NUMERIC(0), STRING(1);

        private final int value;

        ColumnType(int value) {
            this.value = value;
        }

        public int value() {
            return this.value;
        }
    }

}